// function fn(a: any): any {
//   return a
// }

/**
 * 在定义函数或者是类时，如果遇到类型不明确就可以使用泛型
 *       
 */

function fn<W>(a: W): W {
  return a
}

// 可以直接调用具有泛型的函数
fn(20)  //不指定泛型，tS可以自动对类型进行推断
fn<string>('hello') // 指定泛型

// 泛型可以同时指定多个
function fn2<T, K>(a: T, b: K): T {
  console.log(b)
  return a
}

fn2<number, string>(123, 'hello')

interface Inter {
  length: number
}

// T extends Inter 表示泛型T必须是Inter的实现类（子类）
function fn3<T extends Inter>(a: T): number {
  return a.length
}

console.log(fn3('132'))


class MyClass<T>{
  name: T
  constructor(name: T) {
    this.name = name
  }
}

const mc = new MyClass<string>('小王')
